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(54) System and methods for preparing multimedia data using digital video data compression 

(57) Systems and methods are described for pre- the video images, 
paring multimedia data using digital video data com- 
pression. Various embodiments of the invention use 
pre-rendering and encoding techniques that format the 
video image data into fat macroblocks. The fat macrob- 
locks include header information that identifies the 
beginning locations of strips of macroblocks represent- 
ing slices of the image, and of the macroblocks dis- 
posed within the strips. The header information enables 
macroblocks disposed in a strip of fat macroblocks to be 
individually addressed thereby providing transmission 
bandwidth, data processing, and data storage advan- 
tages for preparing and transmitting data for updating 
video images including less than full screen motion. The 
advantages are achieved in part because updates only 
require that the first macroblock of each strip of macrob- 
locks be transmitted. Further efficiencies can be real- 
ized by using a zero displacement motion vector instead 
of the actual values of the first macroblock if the first 
macroblock is not changing. Methods using fat macrob- 
lock formatted data sets provide advantages for encod- 
ing and transmitting large bitmaps of static content, 
scrolling the static content, enabling animation of small 
areas of the display, supporting picture-in picture func- 
tionality, and allowing for overlay and combination of dif- 
ferent image data from different sources on the display 
The methods of preparing the multimedia data include 
pre-rendering a bitmap to create a compressed form of 
the bitmap, and determining a viewable area of the 
video images to be displayed. The viewable area of the 
video images can be smaller than the full-sized area of 
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Description 

CROSS-REFERENCES TO RELATED APPLICATIONS 

5 [0001] This application relates and Incorporates herein by reference as if fully set forth herein United States patent 
application serial number 09/071.549, entitled "Labelling of Links in Hypertext Document Images," filed, May 01. 1998, 
and having inventors Antoine Boucher, Wayne C.Louie, Paul E. McRae, and Peter G. N. Scheyen; and United States 
patent application serial number 09/255,052, entitled "System and Method for Interactive Distribution of Selectable 
Presentations," filed February 22, 1999, and having inventors: Antoine Boucher; James Lee Fischer, and Allan E. Lod- 

w berg, the entire contents of all of which are hereby incorporated herein by reference as if fully set forth herein. 

BACKGROUND OF THE iNVENTION 
Field of the invention 

/5 

[0002] The invention relates generally to the field of preparing multimedia data for transmission. More particularly, 
the invention relates to using digital video encoding techniques to provide efficient use of channel bandwidth and pro- 
vide updates to video images. 

20 Discussion of the Related Art 

[0003] The acceptance of digital video compression standards, such as those included in the Motion Picture Expert 
Group (MPEG) standards (including MPEG-2), combined with high-bandwidth communication infrastructure have posi- 
tioned cable television users with many service selections including video-on-demand, multi-party interactive video 
25 games, and video teleconferencing. Cost-effective versions of these services, as well as Internet access using cable 
television, require improved video composition and display techniques to assure that user expectations regarding clarity 
of image and speed of response are met. 

[0004] Previous solutions for preparing multimedia data using digital video data compression Include those 
described by U.S. Patent No. 5,623,308, issued to Civanlar et al. on April 22, 1997 and U.S. Patent No. 5,691,768, 

30 Issued to Civanlar et al. on November 25, 1 997. According to these solutions, an encoder produces a single coded and 
compressed output stream in slices of macroblocks of pixel data. The output bitstream is demultiplexed into separate 
resolution bitstreams using identifier for each slice and for the first macroblock of each slice. The decoder processes 
the slices within the bitstreams of different resolutions received from plural sources using the identifiers for each slice 
to produce a single composite bitstream of successive slices. 

35 [0005] This technique is well adapted to provide compressed bitstreams for full-screen motion videos. However, the 
technique does not provide additional compression for partial screen motion, or partial screen updates. Examples of 
partial screen motion include partial screen animation, scrolling an image that is larger than the viewing area to view 
obscured areas, and picture-in-picture motion. Partial screen updates include variable input fields, user selection graph- 
ics, and segmented images. What is needed is a system and method that provides additional compression and image 

40 clarity advantages for partial screen motion and partial screen updates. 

SUWIiVIARY OF THE INVENTION 

[0006] A primary goal of various embodiments of the invention is to overcome problems in previous solutions for 
45 preparing data and transmitting data for updating video images that have less than full screen motion. The previous 
data preparation and transmission solutions provide encoding and decoding using frame fonmats and address full- 
screen motion video. These solutions do not adequately address channel throughput and set-top box processing limi- 
tations by using software efficiencies that can be realized by updating and transmitting only portions of the frame data 
for updating video images that have less than full screen motion. 
50 [0007] In accordance with these goals, there is a particular need for pre-rendering, encoding and othenvise fonnat- 
ting data for updating video images that have less than full screen motion. Thus, it is rendered possible to simultane- 
ously satisfy the above-discussed requirements of preparing and transmitting the video data for less than full screen 
motion, which, In the case of the prior art, are not simultaneously satisfied. 

[0008] A first aspect of the invention is implemented in an embodiment that is based on a method for preparing mul- 
55 timedia data using digital video data compression. The method includes pre-rendering a bitmap to create a compressed 
form of the bitmap, the bitmap including content of a series of video images of the multimedia data, the video images 
having a full-sized area; and determining a viewable area of the video images to be displayed, the viewable area of the 
video images is smaller than the full-sized area. 
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[0009] A second aspect of the invention is implemented in an embodiment that is based on a method for transmit- 
ting multimedia data using digital video data compression. The method includes the steps of the first aspect and adds 
the step of transmitting frames of data representing portions of the video images to processing equipment, the process- 
ing equipment is connected to at least one display. 

5 [0010] A third aspect of the invention is implemented in an embodiment that is based on a system for transmitting 
multimedia data using digital video compression. The system includes a crawler adapted to update references to media 
assets disposed in markup language files, and provide content including markup language files to a renderer; the ren- 
derer adapted to render the content into fat macroblock fomnatted data sets; a rendered cache adapted to store files of 
the fat macroblock formatted data sets; a server adapted to submit requests for data to a browser, and deliver encoded 

10 multimedia data streams to a cable network; the browser is adapted to respond to requests from the server by collecting 
data from the crawler and the rendered cache, and submit the collected data to the server. 

[0011] A fourth aspect of the invention is implemented in an embodiment that is based on a method of distributing 
Internet data to digital cable devices. The method includes pulling initial content from the Internet; pre-rendering a bit- 
map corresponding to the initial content to create a compressed form of the bitmap, the bitmap corresponding to a 
15 series of video images of the multimedia data, the video images having a full-sized area; determining a viewable area 
of the video images to be displayed, the viewable area of the video images is smaller than the full-size area; and trans- 
mitting frames of data representing portions of the video images to digital cable processing equipment, the digital cable 
processing equipment is connected to displays for more than one user. 

[0012] A fifth aspect of the invention is implemented in an embodiment that is based on a method of using a televi- 
se slon channel to provide Internet access. The method includes pulling initial content from the Internet; pre-rendering a 
bitmap corresponding to the initial content to create a compressed form of the bitmajD, the bitmap corresponding to a 
series of video images of the multimedia data, the video images having a full-sized area; determining a viewable area 
of the video images to be displayed, the viewable area of the video images is smaller than the full-size area; storing mul- 
timedia data elements including the bitmap in a server system; multiplexing the multimedia data elements into frames 
25 of data; transmitting frames of data from the server system to a cable network; and transmitting streams of data repre- 
senting portions of the video images in a television channel to digital cable processing equipment, the digital cable 
processing equipment is connected to at least one display for a user. 

[0013] A sixth aspect of the invention is implemented in an embodiment that is based on a method of providing a 
picture-in-picture display. The method includes pre-rendering a bitmap to create a compressed form of the bitmap, the 

30 bitmap including content of a series of video images of the multimedia data, the video images having a full-sized area; 
determining a viewable area of the video images to be displayed, the viewable area of the video images is smaller than 
the full-sized area; rendering the content of the video image; and updating macroblocks for a portion of the viewable 
area corresponding to a picture-in-picture display, the updated macroblocks including one or more of predicted frames 
and bi-directional frames including images corresponding to full motion for the picture-in-picture display. 

35 [0014] These, and other, goals and aspects of the invention will be better appreciated and understood when con- 
sidered in conjunction with the following description and the accompanying drawings. It should be understood, however, 
that the following description, while indicating preferred embodiments of the invention and numerous specific details 
thereof, is given by way of illustration and not of limitation. Many changes and modifications may be made within the 
scope of the invention without departing from the spirit thereof, and the invention includes all such modifications. 

40 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0015] A clear conception of the advantages and features constituting the invention, and of the components and 
operation of model systems provided with the invention will become more readily apparent by referring to the exemplary, 
45 and therefore non-limiting, embodiments. The embodiments are illustrated in the drawings accompanying and forming 
a part of this specification, wherein like reference characters (if they occur in more than one view) designate the same 
parts. It should be noted that the features illustrated in the drawings are not necessarily drawn to scale. 

FIG. 1 illustrates a fat macroblock formatted image layout, representing an embodiment of the invention. 

50 

FIG. 2 illustrates strips of fat macroblocks with corresponding fat macroblock headers, representing an embodiment 
of the invention. 

FIG. 3 illustrates a system for transmitting video data, representing an embodiment of the invention. 

55 

FIG, 4 illustrates a method for transmitting multimedia data using digital video compression, representing an 
embodiment of the invention. 
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DESCRIPTION OF PREFERRED EMBODIMENTS 

[0016] The invention and the various features and advantageous details thereof are explained more fully with ref- 
erence to the non-limiting embodiments that are illustrated in the accompanying drawings and detailed in the following 
5 description of preferred embodiments. Descriptions of well-known components and processing techniques are omitted 
so as not to unnecessarily obscure the invention in detail. 

[001 7J Various embodiments of the invention overcome problems in previous solutions for preparing data and 
transmitting data for updating video images that have less than full screen motion. The previous data preparation and 
transmission solutions provide encoding and decoding using frame fonnats and address full-screen motion video. 
w These solutions do not adequately address channel throughput and set-top box processing limitations by using soft- 
ware efficiencies that can be realized by updating and transmitting only portions of the frame data for updating video 
images that have less than full screen motion. 

[0018] Various embodiments of the invention apply video data compression techniques to update and transmit 
frame data including only portions of the data sent by previous solutions. Only the data required for updating video 

75 images within a predefined viewable area (or display window) are encoded and transmitted. Further reduction of the 
data is accomplished by only encoding data for macroblocks that require updating. This reduction is accomplished 
using a fat macroblock format including fat macroblock files and a header entry for each group of fat macroblocks rep- 
resenting a horizontal slice of the image. The groups of fat macroblocks representing horizontal slices of the image are 
also referred to herein as "strips", or "fat macroblock strips". For a series of images having less than full screen motion, 

20 substantial data processing and transmission channel bandwidth reductions are realized Despite the strip-based struc- 
ture, the fat macroblocks fomnat allows access to each macroblock in the image data set randomly, not just on a strip 
by strip basis. 

[0019] According to various embodiments of the invention, the video image content includes fixed content and var- 
iable content. Fixed content includes portions of the video image content that will not vary with respect to its lifetime 

25 within an image. For some embodiments, the lifetime is the time for which an image including content is displayed. 
Examples of fixed content include background color or images, static text and static images. 
[0020] Variable content includes portions of the content that may vary with respect to its lifetime within an image. 
For example, a form element may have its text updated, a radio button can be toggled, and an area of the screen des- 
ignated as a picture-in-picture display will also be updated during the lifetime of the image. An image can be animated, 

30 with or without timing (e.g., an animated GIF). 

[0021] Various embodiments of the invention use data sets organized in macroblocks to represent portions of the 
video image. The macroblocks represent geometric arrays of pixels on the display. 

[0022] MPEG formatted data uses three basic types of frames in encoding a video stream: an intra-frame, a pre- 
dicted frame and a bi-directional frame. The intra-frame. or i-frame, is used to provide still frame images that fill the 

35 entire screen. The capture of an i-frame results in a pivot point from which p-frames and b-frames (discussed below) 
can modify the appearance of the screen. An i-frame does not use any predicted, previous, or future frames. 
[0023] The predicted frame, or p-f rame, represents moving a captured i-frame via a motion vector or replacing part 
of a screen. Predicted-frames come in a linear sequence after an i-frame and represent transformations on that i-frame. 
The bi-directional frame, or b-f rame, can be sent in a stream that represents transformations on both an i-frame and a 

40 p-f rame. The b frame is a frame that requires the context of previous and future frames. 

[0024] Various embodiments of the invention use i-, p-, and b- frame attributes to reduce real-time processing and 
software requirements for manipulating and processing image data at the receiving client platfoma (e.g., a set-top box 
or addressable processing equipment). These embodiments combine video processing ability at the set-top box (STB) 
with "pre-rendered" format data comprising MPEG compliant data to minimize software and processing required at the 

45 STB, and to provide faster downloading of content to a user. The methods are especially advantageous for Internet 
browsing on a TV screen using an oversized bitmap of the web page contents. The user can readily view a portion of 
the page (with sufficient magnification and clarity of text) and can scroll to view other portions of the page as desired. 
[0025] The invention can be implemented using the existing MPEG standard to provide the user with partial screen 
updates, picture in picture, smooth scrolling, and animation. The concepts described can also be applied to any digital 

50 video compression system. 

[0026] Various embodiments of the invention can be implemented to provide processes and data formats that 
encompass preparation and transmission of content using the MPEG standard and enable MPEG devices to exhibit 
capabilities beyond what their designers intended. 

55 Definitions 

[0027] For the purposes of this document, the following terms are defined: 
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Passive Area - The portion of variable content that will not change as the variable content changes. For exannple, 
the non-changing box around the changing text of a text entry form element. 

Active Area -The portion of an instance of a variable content that may change as the variable content changes. For 
5 example, the internal shape or color of a radio button that Is toggled, or the text contents of a text form element, or 
the area of the screen updated during a scroll or picture-in-picture operation. 

Fat Macroblock - A specific encoding of a macrobtock such that, when read back or used later, the internal values 
of the macroblock can be easily manipulated without having to bit wise and/or byte wise unpack the macroblock 
10 before such manipulation prior to encoding or re-encoding the macroblock before delivery. 

Fat Macroblock Format - The fat macroblock (FMB) format organizes the macroblocks along with additional infor- 
mation that makes access and manipulation of the macroblock data fast. The format enables the application to 
combine macroblock data from several sources into a single video operation. In some embodiments of the inven- 
15 tion, all macroblocks used in an image are encoded using the same quantization matrix as the original intra-frame 
of the image. The intra-frame is the base data upon which updated information is added. Note that in some embod- 
iments, each macroblock can be encoded with its own quantization scale factor. The FMB format is described in 
greater detail in the Fat Macroblock Format section below. 

20 Changeable Region - A portion of the user screen which can possibly be updated via the content after the initial 
display For example, scrolling a region, or changing the value of a form element anywhere in that region. 

Permanent Region - A portion of the user screen that will not change in any way via the content. For example, an 
HTML frame that has no form elements, no animated GIFs, does not need to be scrolled by the user, and contains 
25 no other content that might be updated or changed. Another example is a runtime chosen and/or inserted static 
image on top of the original content. 

Fat Macroblock Format 

30 [0028] Figure 1 shows a fat macroblock (FMB) formatted image layout 1 00 representative of some embodiments of 
the invention. The FMB formatted image includes active content areas. The macroblocks can be organized as macrob- 
lock strips corresponding to horizontal slices of the video irhages, such as the macroblock strip 1 10 of row A. The FMB 
formatted image layout 100 shows how active content areas are laid out in an MPEG system with 16x16 pixel macrob- 
locks. The macroblock side dimension of 16 is also referred to as "N" below. Note that placing N/2, or 8 pixel, border 

35 surrounding each active content area ensures that each active area of the content is completely contained within mac- 
roblock boundaries, and as such can be updated using p-frames. 

[0029] The FMB formatted image layout 1 00 includes a 6 x 7 array of macroblocks; "x" denotes the fat macroblocks 
that make up the entire image. The macroblocks are arranged in horizontal "strips" labeled A through G, and in columns 
1 through 6. 

40 [0030] The FMB fonmatted image layout 100 also includes a first active area 120, a second active area 130, a first 
border area 140, and a second border area 150. The first active area 120 (designated "z") is the active, variable area 
that will be updated, and is surrounded by the first border area 140 (designated "y"). The first border area 140 provides 
an 8 pixel border around the first active area 120. Adding the border to active elements of the picture ensures that the 
macroblocks changed to update any active element are not shared with any other active element. 

45 [0031 ] The second active area 1 30 (designated "w") is surrounded by the second border area 1 50 that provides an 
8 pixel border around the second active area. The second active area 130 is included to demonstrate that use of the 8 
pixel border will result in an image in which multiple variable areas do not share any macroblocks. 
[0032] To update the first active area 1 20, a p-f rame is created containing data for macroblocks C2 through C5 and 
D2 through D5, The rest of the macroblocks will be sent as motion vectors having a value of zero, or as skip blocks. To 

50 update the second active area 130, macroblocks E4 through E6 and F4 through F6 are sent with new data, and the 
remaining macroblocks are sent as motion vectors having a value of zero, or as skip blocks. 

[0033] Figure 2 illustrates an FMB formatted image 200 including an FMB image header, representing an embodi- 
ment of the invention. This FMB format enables the application to quickly and easily combine macroblocks from various 
sources into a singe video operation, typically a sequence of i- and -p frames. 
55 [0034] The data for the FMB formatted image 200 includes at least one strip of macroblocks. In the FMB fonmat an 
FMB image header 210 is provided for the entire image. The FMB formatted image 200 shown in Figure 2 includes a 
first macroblock strip 220, and second macroblock strip 230 and a third macroblock strip 240. 
[0035] The FMB image header 210 includes an entry for each macroblock strip. The FMB image header 210 
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includes a first header entry 212 corresponding to the first macroblock strip 220, a second header entry 214 corre- 
sponding to the second macroblock strip 230, and a third header entry 21 6 corresponding to the third macroblock strip 
240. The entry for each strip points to the location of the beginning of the strip and also contains a pointer to the begin- 
ning of each macroblock within the strip. 

5 [0036] Each fat macroblock has its own header that contains information such as the quantization-scaling factor. As 
shown in Figure 2, the first header entry 212 includes a first macroblock entry 250, a second macroblock entry 260, and 
a third macroblock entry 270. The first macroblock entry 250 corresponds to the first macroblock 221 in the first mac- 
roblock strip 220. The second macroblock entry 260 corresponds to the second macroblock 222, and the third macrob- 
lock entry 270 corresponds to the third macroblock 223. Given multiple sources of FMB data in this format, the elements 

10 from each file can be extracted and assembled into a p-, b-, or i-frame and delivered to the decoder. The FMB forniat 
ensures that the assembling process has enough information to create a valid frame from disparate data sources. 
[0037] A macroblock is the smallest unit that can be identified without decoding the bitstream. Various embodi- 
ments of the Invention enable the application to compose an update from macroblocks from several sources without 
having to decode and re-encode the macroblocks. The pointer is provided in the each strip header entry for each mac- 

J5 roblock in the strip because the macroblocks vary in bit length. The application can use these pointers to access any 
macroblock in the data set (stream) individually for use in composing an update frame. 

System for Preparing Multimedia Data Using Digital Video Data Compression 

20 [0038] Various embodiments of the invention providing a system for preparing multimedia data 300 using digital 
video data compression are represented by FIG. 3. The system for preparing multimedia data 300 includes a server 
system, a client, an interactive application environment library, and content tools. Various embodiments of the system 
are described in detail in United States patent application serial number 09/255,052, entitled 'System and Method for 
Interactive Distribution of Selectable Presentations," filed February 22, 1999, which is incorporated herein by reference 

25 as if fully set forth herein. 

[0039] The system for preparing multimedia data 300 pulls content from the web in the form of hypertext markup 
language (HTML), pulls interactive video (ITV) in the fomn of television markup language (TVML), and stores the HTML 
and ITV data in the server system. TVML is an extensible markup language (XML) language designed to specify inter- 
active content for television. A rendering process converts content into FMB formatted data sets that can be easily dis- 

30 played. The FMB data sets can be stored as fat macroblock files and as files in a video markup language:-The video 
markup language files are adapted to provide infonnation that directs placement of data from the FMB files on the bit- 
map and on the screen or display 

[0040] The server system is connected to the Internet 302, and can include a scheduler 304, a supervisor 306, a 
session manager 308, a crawler 316, a source cache 318, a renderer 320, a rendered cache 330, a browser 340, an 
35 audio video temninal server 345, and an input server 350. 

[0041] The server system is connected to the client by a cable network 355. The client includes a client platform 
360, and is connected to a display 370. 

[0042] The interactive application environment (lAE) can include a navigator, applications related to the navigator, 
and an lAE library. The content tools include a TVML, a TVML pre-viewer, and a content converter. 
40 [0043] The functions of several components of the server system are important for the preparation of the multime- 
dia data using the FMB format 

[0044] For some embodiments of the invention, the scheduler 304 makes regular, scheduled requests to the 
crawler 316 to fetch content from pre-conflgured sites. The scheduler 304 is adapted to ensure that the content is 
fetched, rendered, and copied to the appropriate locations for use. 

45 [0045] For some embodiments of the invention, the supervisor 306 is responsible for starting up the system and 
monitoring the state of the system. A configuration file is read when the supervisor 306 is started up and specifies which 
processes are to be started on the host computer. The host computer typically uses a Unix operating system, but the 
invention can function using other operating systems. The supervisor 306 then creates the specified processes and ver- 
ifies that the specified processes are running correctly. During system operation, the supervisor 306 monitors the state 

50 of the processes and performs appropriate recovery operations (for example, restarting a failed process) based on 
information in the configuration file. 

[0046] For some embodiments of the invention, the session manager 308 is the flash point for interactive session 
creation. System resources (such as applications and servers) register with the session manager 308 on startup. When 
a client (e.g.. a set-top box) attempts to log on to the system, the session manager 308 checks to ensure that the appro- 
55 priate resources are available and creates a session. The application required by the session is then notified. During 
the session, if another application is requested, control passes back to the session manager 308. Rnally, when the ses- 
sion is terminated, the session manager 308 makes sure that all of the resources allocated to the session are freed. 
[0047] A crawler 316 can be used to access and pull in content from the Internet 302. Based on requests, the 
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crawler 316 connects to a web server at a particular site and pulls in content, w^lich may be in the form of TVML or 
HTML The content is then stored on the server in a disl< cache, such as the source cache 318. The crawler 316 
ensures that all of the assets relating to a particular piece of content are pulled and cached and performs some trans- 
formations on the content (converting hnp'M to file:// where appropriate, for example). 

5 [0048J The source cache 31 8 can include HTML and TVML data that has not yet been pre-rendered into the FMB 
format The source cache 318 can also Include TVML flies that specify image files already formatted as FMB data sets. 
[0049] The renderer 320 is adapted to create FMB data sets from different input sources. The input sources can 
include markup languages, standard and non-standard image file formats, and live image data (e.g., a telecast). The 
renderer 320 contains the compression algorithm, and outputs results from the compression algorithm as described by 

10 the FMB data set format. The renderer 320 converts video data into an FMB format. In some embodiments, the ren- 
derer 320 takes in HTML and TVML, with their accompanying assets (GIPs, JPG's, pre-encoded FMB files), and cre- 
ates the FMB formatted data set. The renderer 320, or rendering engine, can include a device mosaic 322 and a 
graphics language 324. 

[0050] The rendered cache 330 includes bitmaps and frames formatted according to the FMB fonnat in FMB files. 
15 The rendered cache 330 can also include markup language files indicating how the FMB files are assembled for a par- 
ticular image. The indications of how the FMB files are assembled for a particular image can also be stored in a data- 
base, or as part of the FMB file itself. 

[0051] The browser 340 collects data from the crawler 316. and the rendered cache 330 in response to requests 
from the audio/video tenminal server (AVTS) 345, and forwards the data to the AVTS for transmission to the user. 
20 [0052] The audio/video temninal server (AVTS) 345 is responsible for delivering encoded data streams (e.g., MPEG 
video and Dolby AC-3 audio streams) to client platfonTis 360 (e.g., set-top boxes). A special MPEG multiplexer card 347 
can be controlled by the AVTS 345 to stream data onto one or more cable networks 355. 

[0053] The AVTS 345 can also send terminal commands through the cable network 355 to the client platform 360. 
e.g., a set-top box. The terminal commands can instruct the set top box to draw text and graphic overlays, display hot 
25 regions, and realize input widgets. The input widgets can include those described by United States patent application 
serial number 09/071,549, entitled "Labelling of Links in Hypertext Document Images." filed, May 01, 1998, which is 
incorporated herein by reference as if fully set forth herein. 

[0054] The input server 350 receives input from the user's set-top temninal. Both two-way cable and modenn/phone 
return are supported. Input events from the set top box are passed to the appropriate application for processing. The 
30 input server 350 typically utilizes special hardware to obtain the user input from the two-way cable plant. 

[0055] Various embodiments of the invention can operate without requiring any special processing in the client plat- 
form 360 or other addressable processing equipment (e.g.. set top box) to accomplish any of the functionality described 
herein. No special client applications are required. Instead, this functionality is inherently provided by the video subsys- 
tem of the current set top box through the set top box MPEG decompression and frame buffer system. 
35 [0056] Typically, the client platform 360 processes data according to a terminal, text, and graphics (TTG) protocol. 
The TTG protocol is a thin-wire protocol, which enables the server to communicate with the set top box. TTG protocol 
provides capabilities including drawing text and graphics, manipulating hot-zones, and presenting graphical 'widgets' for 
display and user input Several aspects of the TTG protocol are described in United States patent application serial 
number 09/071,549, entitled "Labelling of Links in Hypertext Document Images, which is incorporated herein by refer- 
ee ence as if fully set forth herein. 

[0057] The lAE can include a navigator that is the standard application used to navigate the ITV content. In addi- 
tion, the navigator can navigate general web content by utilizing the resources of the crawler 31 6 and the renderer 320. 
Applications (which include the navigator) use a high-level object-oriented library to create and display presentations. 
This library communicates with other server components to deliver media to the user's set top box. 
45 [0058] One of the core applications is the interactive program guide that provides the user with up-to-date informa- 
tion on television program schedules, pay-per-view, and video-on-demand services. The lAE can also include a library 
to provide application programmers with an object-oriented library (e.g., C++) for developing interactive television appli- 
cations. The lAE library abstracts and simplifies the task of creating ITV applications and eliminates the complexity of 
communicating with the system software at a low level. 
50 [0059] Content tools include TVML. TVML is an extensible SGML specified language, which allows content crea- 
tors to produce content specifically aimed at the television viewer. Using TVML the creators can play slide shows, add 
background audio and timing, and overlay text and graphics on images. The video content for the system for preparing 
multimedia data 300 typically includes TVML combined with HTML. 

[0060] The TVML pre-viewer is a platform-independent tool capable of displaying TVML to a user for the purposes 
55 of developing TVML content. 

[0061] The content converter works in conjunction with an appropriately configured web server to ensure that all of 
the content on that server is ready to be pulled into a cable network 355 head-end. The converter converts Targa, 
JPEG, BMR GIF, PCX, MES, MT1 , TGA, PNG, or any image file format files into MPEG; and converts WAV, ATI , AES, 
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AVI, PCM, au, vox. or any audio format files into Dolby AC-3. 

[0062] The AVTS 345 can be adapted to read FMB data and create valid digital video streams therefrom. In some 
embodiments, the application (e.g., browser or guide) requests that the screen be updated by specifying the areas of 
the screen to be updated. The application can also specify how the areas are to be updated (e.g., replace the area, 
5 scroll the area, move the area), and the new image data to be placed on the screen (by specifying which macroblocks 
from which FMB files are to be used). 

[0063] The AVTS 345 then assembles the necessary macroblock data by reading the FMB files, and creates the 
appropriate MPEG frames (i-. p-. and/or b-frames) and transmits the frames to the client platfonn 360 via the cable net- 
work 355. If necessary the AVTS 345 then sends the empty p-frame to 'push' the previous update frames out. 

10 

Methods of Preparing Multimedia Data 

[0064] MPEG is designed to encode full motion video into a compressed digital stream taking advantage of the 
redundancy between frames. MPEG encoders typically analyze the video steam and generate a series of i-, p-, and b- 

15 frames representing a compressed version of the original source material. Various embodiments of the invention use 
the functionality provided by MPEG to provide a completely different set of features. These embodiments encode large 
bitmaps of static content. Then, using MPEG techniques and fat macroblock formatting, these embodiments provide for 
the display and scrolling of the static content, enable animation of small areas of the display, support picture-in-plcture 
functionality, and allow for amalgamation (overlay and combination) of different image data on the display 

20 [0065] For example, consider the problem of displaying a web page on a television screen. The entire web page 
cannot fit in the confines of the display since the screen is too small to enable reading of character data at typical tele- 
vision screen viewing distances. Various embodiments of the invention generate a bitmap representing the entire web 
page (perhaps 2000x4000 pixels in size) and encode this data in a manner that allows an application in real-time to dis- 
play only a screenful of data (perhaps only 640x480 pixels in size) at a time. 

25 [0066] Normally, encoding a bitmap of a static image is not an application of MPEG technology because the bitmap 
does not display full motion video, only static screen data. Within that web page, however, there may be animated GIF 
files. Display encoding according to various embodiments of the invention provides updating for only the portion of the 
screen occupied by the animated image, and animates the image by encoding MPEG data that represents these partial 
screen updates in real-time. One aspect of various embodiments of the invention includes an algorithm adapted to lay- 

30 out the Image content so that the portion of the screen that is being updated does not overlap other areas of the screen 
that are being changed. The ability to easily generate MPEG data in real-time allows us to smoothly scroll the screen 
in any direction using motion vectors and partial screen updates. 

[0067] Various embodiments of the invention encode and store the bitmap data into an MPEG fonnat with addi- 
tional information that enables quick retrieval of the MPEG data, and creation of valid i-, p-, and b-frames in real-time. 

35 The macroblock in an FMB fonnatted data set can be manipulated without decoding of the macroblock back into the 
original bitmap image fonn in which the macroblock is disposed. No Inverse DCT (Discrete Cosine Transfonn) needs to 
be perfomned to manipulate a macroblock formatted as FMB. For example an MPEG macroblock of 16x16 pixels can 
be encoded using the Discrete Cosine Transform (DCT), quantized according to a quantization matrix, and the resulting 
data compressed using Huffman encoding. 

40 [0068] The resulting data block can be manipulated without altering the data if the data is stored in a manner such 
that the variable elements (quantization scale factor, matrix, and color space) are known. Previous MPEG encoders 
have been designed to encode full motion video, and do not provide this ability to store large bitmaps bigger than the 
screen display MPEG encoding technology that does not use FMB formatted data sets and file formats is not designed 
for on-the-fly generation of MPEG data to provide scrolling and partial screen updates in the manner described above. 

45 [0069] This ability to efficiently manipulate encoded MPEG data, i.e., because it is encoded using our fat macrob- 
lock technique, allows for a picture-in-picture scheme where a full motion window is displayed on top of a static back- 
ground. Using the image combination capabilities of b-frames also allows us to encode the background image with one 
quality and an overlay image with another (for example, encoding the background picture with a lower quality than the 
overlaid text). Without the FMB encoding scheme, generating valid MPEG streams from the original bitmap data in real- 

50 time would be prohibitively difficult because of the large amounts of processing power required. Various embodiments 
of the invention allow the application to specify a region of the FMB data to be displayed, and a target area of the screen 
to be updated. In real-time, the application can generate an MPEG stream (for example, a p-frame) that represents 
updating the desired portion of the screen without consuming excessive processing resources. The application 
achieves this by reading the macroblocks out of the FMB data sets (which are indexed with header information for quick 

55 lookup and access), adding the necessary headers for the data stream, and streaming the data onto the network. 
[0070] Various embodiments of the invention also allow for the FMB data to come from many disparate files and 
then combined into a single MPEG frame. For example, a full or partial screen replacement can be generated from 
three different FMB data sets and sent as a single p-frame or i-frame update. These approaches provide solutions to 
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the problem of efficiently displaying large amounts of static and animated bitmap data using MPEG (or other compara- 
ble digital video standards). 

[0071] As shown in Figure 4, various embodiments of the invention provide a method for preparing multimedia data 
for transmission using digital video data compression. The method for preparing multimedia data comprises pre-ren- 

5 dering a bitmap (block 410), and determining a viewable area of the video images to be displayed (block 420). Pre-ren- 
dering of the bitmap creates a compressed form of the bitmap. The bitmap includes content of a series of video images 
of multimedia data The video images have a full-sized area. The viewable area can be smaller than the full-sized area. 
[0072] Some embodiments of the invention provide a method for transmitting multimedia data using digital video 
data compression. These method include pre-rendering (block 41 0) and determining the viewable area (block 420); and 

10 also include transmitting frames of data representing portions of the video images to processing equipment (block 430). 
The processing equipment is connected to at least one display 370. 

Process Description 

>5 [0073] This section describes the basic processes involved in preparing, manipulating, encoding, and delivering 
content. 

Content Preparation Content preparation ensures that the active areas of any variable element do not share any 
macroblocks with any active area of any other variable element. This allows the variable areas to be updated inde- 
20 pendently. 

[0074] The following is a non-exhaustive list of possible pre-processing, or preparation, steps: 
[0075] An HTML frame can be made to have its left boundary adjusted so that it begins on the leftmost pixel loca- 
tion of a macroblock, landing in either the cun*ent macroblock if the left edge is already at the leftmost pixel location, or 

25 else the next macroblock to the right of the cun-ent macroblock. Similarly, the right boundary is adjusted so that it lands 
on the rightmost pixel location of a macroblock. Similarly, the top boundary is adjusted so that it lands on the topmost 
pixel location of a macroblock. Similariy, the bottom boundary is adjusted so that it lands on the bottom most pixel loca- 
tion of a macroblock. The edges may or may not be adjusted to include or exclude any frame delimiters. 
[0076] An HTML form element can be created or adjusted so that the fomn element maintains a minimum n/2 pixel 

30 wide passive area (where n is the macroblock size) around the perimeter of the set of all active areas of the form ele- 
ment. This passive area ensures that the form element does not encroach on another HTML element that needs to be 
updated, and ensures that the active area of the content is within an area that is bounded by macroblocks. For example 
an MPEG system with 16 pixel x 16 pixel macroblocks would have an 8-pixel border around such elements. 
[0077] An animated GIF can be size adjusted to include a passive area around each of the images in the animated 

35 GIF of at least n/2 pixels, so that the resultant images are all of the same size. Alternatively, the images within the ani- 
mated GIF can be set to the largest image within the animated GIF, or the content encoding step can ensure sufficient 
information is kept to allow clearing of the necessary regions on the user screen or intennediary device at runtime. 
[0078] MPEG video data can be modified either in real-time, or prior to transmission, to update only a portion of the 
screen, resulting in a picture-in -picture effect for the end user. 

40 

Content Separation The content can be separated into regions of the screen. A region is either changeable or per- 
manent. Permanent regions can optionally be collectively encoded into a single static macroblock file. Regions can 
occur as a result of HTML frames, TVML windows, or any other directive. For each of the regions, the steps for con- 
tent decoding/rendering and content encoding are performed, and the resultant infonnation is identified by region, 
45 or otherwise kept separately by region. Content changes are handled separately for each region. 

Content Decoding/Rendering The content can be decoded and/or rendered into a series of bitmaps. One bitmap 
can be created first with all of the static elements, including the static background colors, bitmaps, etc., upon which 
the variable content will be placed. Then, for each variable element, such as form elements and animated GIFs, the 
50 appropriate sections of the bitmaps can be extracted and saved permanently. 

Content Encoding For the static content, a single file can be created with fat macroblocks. Then, in encoding some 
variable elements such as animated GIFs, the entire set of instances of the element (e.g., each image within an 
animated GIF) can be encoded into fat macroblocks using the extracted bitmap. For the remaining variable element 
55 types, the saved bitmaps can be used later at runtime to generate the necessary macroblocks based on the runt- 
ime changes to the variable elements. Alternatively, some of the passive portions of these variable elements can 
be pre-encoded into fat macroblocks. 

The resultant set of files and fat macroblocks can also be tracked using a specifier such as a table of contents 
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file, database, or markup language. The remaining steps can use the set of files of fat macroblocks, bitmaps and 
specifiers. 

The encoding process can output the values within macroblocks in either a compressed form, or in an 
expanded form, to facilitate future modification or usage of the values. During the encoding of the variable ele- 
5 ments, portions of the variable elements, such as an initial value or an initial display can be placed into the static 
set of macroblocks. 

Content Changes At runtime, the variable elements can undergo changes. For such changes, the saved bitmap of 
the area for the variable content is used to decode and/or render new values. The new values are then re-encoded 
10 into fat or regular macroblocks. Any portion of a variable content that changes can be sent immediately, or later, as 
desired. 

Content Delivery The content delivery step includes pulling together the macroblocks to be displayed, and then 
transmitting the macroblocks to the user display 1 70 device. The application designates which areas of the screen 
15 are to be updated, and from which macroblock data these areas will be updated. 

If the entire screen is to be updated, then an i-f rame can be generated from the macroblock data. If only a sub- 
set of the screen is to be updated, a p-frame is created containing the necessary macroblocks. Should it be neces- 
sary to move or scroll data, motion vectors can be included in the p-frame delivery. 

Before and/or during packing of the macroblocks, various fields within the set of macroblocks to be transmitted 
20 are calculated or re-calculated. This calculation can include the DC (highest frequency discrete cosine transforma- 
tion matrix value) components, the delta values, the coefficients, and combinations thereof. 

Content Updating As users interact with the content, various portions of the content can be changed in real time. 
These changes can include scrolling content within regions, updating or changing elements, and animated GIF 

25 images. For each variable element or other change or set of changes, the application (and the AVTS 345) collects 
the macroblocks that are to be changed. Content updating can include initial runtime rendering of data from the 
saved bitmaps into macroblocks. In an MPEG system, content updating can include marking the bitmap with the 
updated macroblock infomnation, updating the fields as necessary for the macroblocks to be sent, and then creating 
the p-frame (or optionally, an.i-frame). Bi-directional frames can also be used or added to create special effects 

30 (e.g.: fades, wipes, or other image amalgamation effects). 

In an MPEG system, to create a p-frame, the application determines any motion vectors required, usually as a 
result of scrolling of the macroblocks. Then, if necessary, the application creates macroblocks with zero motion vec- 
tors for the left edges of the user display 370 device to establish the required initial values for the fat macroblock 
strip. Then the application calculates and/or re-calculates the fields (as per content delivery) within the macroblocks 

35 to be sent. The application can include or add skipped macroblocks as necessary within the p-frame. 

To use an i-frame instead, the application packs all the necessary macroblocks into an i-f rame without the use 
of motion vectors and/or left-edge zero motion macroblocks. 

Applications 

40 

[0079] 

Animation Animation (for example, animated GIF's on web pages) can be accomplished by pre-encoding FMB files 
containing each frame of the animated GIF The host system can then play these frames according to the timing 
45 contained in the original file. Animation can also be done on the fly in real-time, with the frames and timing deter- 
mined by the application. 

Picture-in-Picture A video stream can be pre-encoded or encoded in real-time as macroblocks for display in an area 
of the screen resulting in a picture-in -picture effect. For a series of images providing a picture-in-picture (PIP) dis- 

50 play, only the macroblocks for the PIP area of the screen contain updated data. The FMB formatted data sets can 
be encoded to represent an MPEG data stream corresponding to full motion video for an area smaller than the vis- 
ible screen size. The compressed FMB formatted data sets can be streamed to the set top box. 

Using the FMB capabilities for building valid MPEG streams in real-time, the full motion portion can be placed 
anywhere on the screen. The full-motion portion can include data streams transmitted in real-time from live video 

55 sources. The picture-in-picture updating can utilize p- and b-frames to update a subset of the screen either by 
replacing the small area entirely (as an i-frame does for the entire screen), by using motion vectors (to do panning, 
for example), and by using b-frames to combine the contents of the screen with new data. 

Given that a certain window is updated, one approach is to transmit 30 p-frames per second to replace the 
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entire window with a new innage. This approach is analogous to sending 30 i-frames a second to replace the full 
screen and is fairly inefficient. A slower transmission rate could also be used to reduce channel bandwidth usage, 
but would suffer from a degraded image transition. However, encoding the frames as FMB data sets, and transmit- 
ting p-frames (and perhaps b-frames) of the FMB data to change only a part of the window contents, makes trans- 
5 mission more efficient without loss of image transition quality. This capability can be covered by the ability to send 

p-frames that entirely replace the PIP 

image Amalgamation Image amalgamation, such as fading or wiping, can be accomplished using p- or b-frames. 
Video images or text can be composited into a background image without having to encode the background data 
10 into the video operation. An example of image amalgamation is discussed in greater detail in Example 5, below. 

Smooth Scrolling By using motion vectors, b- and p-frames, a very smooth scroll of content in any direction can be 
achieved. The smooth scrolling enables the user to view different portions of a page that is not viewable in its 
entirety on the user display 370. A discussion of one method of obtaining smooth scrolling using FMB fomnatted 
15 data sets is provided below in Example 2. 

Example 1 : Displaying Text Portions of an Image with Improved Resolution 

[0080] As an example, a viewable area of a bitmap can be sent as an i-frame. The source material for the bitmap 
20 is at a first resolution level, e.g., 800x600. A p-frame updating a text portion of the viewable area comes from source 
material at a second resolution level, e.g., 1 600x1200. A series of p-frames and/or b-frames corresponding to a picture- 
in-picture display that updates another portion of the viewable area comes from source material at a third resolution 
level, e.g., 640x480. The series of images viewed by the user includes source materials at three different resolution lev- 
els. 

25 [0081] The FMB format allows the application to encode content that contains a background image with text by 
encoding the macroblocks that contain only the background image with a larger quantization scale factor, and the mac- 
roblocks containing text with a smaller scale factor. This can be done to ensure that a viewer can easily read an updated 
text portion of the image. 

[0082] The larger quantization scale factor for the background image data results in a smaller corresponding mac- 
30 roblock data set, with a commensurate loss of image quality. This is acceptable because the user is not adversely 
affected by the loss of background image quality. More importantly, the larger quantization scale factor for the back- 
ground image data reduces the channel bandwidth and processing time required to transmit the con-esponding stream 
of data. 

[0083] The smaller quantization scale factor for the text data results in a larger corresponding macroblock data set, 
35 i.e. less compressed than the background macroblock data set. Therefore, the text is provided with a higher image qual- 
ity. The result is in an image provided on the display having clear text, while maintaining the ability to efficiently com- 
press the image data back at the AVTS 346. 

[0084] Previous implementations of macroblock encoding did not include pointers to individual macroblocks. There- 
fore, one of the limitations characteristic of those implementations is that the smallest unit of data that can be identified 
40 in the coded and compressed bitstream associated with a frame of data without decoding the bitstream is a slice, or 
strip. The positions of the other macroblock address increments in the bit stream of data for each slice vary in accord- 
ance with the variable-length coded data and therefore can not be retrieved without decoding the bitstream. 

Example 2: Smooth Scrolling 

45 

[0085] By using motion vectors, b- and p-frames, a very smooth scroll of content in any direction can be achieved. 
A sequence of frames is sent to the decoder moving the data one macroblock strip at a time. The FMB encoding 
scheme makes creation of the sequence of frames possible in real-time. 

[0086] Referring to the FMB formatted image layout 1 00 shown in Figure 1 , the viewable area of the screen can be 
50 a rectangular region including macroblocks A1 through C4. To smoothly scroll the screen, a sequence of the following 
frames can be sent to the decoder: 

Step 1 : an i-frame for rectangle A1 - C4 

Step 2: a p-frame motion vector to translate Bl - C4 to occupy location A1 - B4 
55 Step 3: a p-frame replacement for block C1 - C4 with data from D1 - D4 
Step 4: an empty p-frame to 'push out resulting image 
Step 5: repeat Steps 2-4 until desired area is being viewed 
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[0087] Note that Step 4 is required because the video subsystem in the set-top box buffers the incoming frames and 
does not play the last frame until the next frame arrives. The empty p-frame is sent, therefore, to push out the last frame 
played, such as the scrolling motion vector p-frame request. The empty p-frame includes all macroblocks coded as skip 
blocks. 

5 

Example 3: Displaying a Previously Cached Web Page or TVML Content 

[0088] The browser 340 application, through user input, can be requested to play a particular URL. The browser 
340 translates this URL into a form that represents the URL location on disk in the server system. The browser 340 

10 checks this location for the existence of a markup language file in the rendered cache 330. If the file exists, this means 
that the content is present The markup language file is read, thus informing the browser 340 of the location of the FMB 
files and/or TVML i-frame files, and audio files necessary to display the content. The browser 340 then makes a request 
to the AVTS 345 to play a part of the FMB file (either a full screen as an i-frame, or part of a screen for a scroll or ani- 
mated GIF update). The AVTS 345 then reads the FMB data and creates the necessary i- or p-frame and streams the 

75 frame through the MUX hardware (e.g., the MPEG multiplexer card 347) onto the cable network 355. The frame is cap- 
tured by the set top box and displayed. 

Example 4: Displaying an Uncached Web Page or TVML Content 

20 [0089] If no file for the requested URL is present in the rendered cache 330, the browser 340 makes a request to 
the crawler 316 to fetch the URL from the Internet. The crawler 316 connects to the web server specified in the URL 
and obtains the HTML or TVML file, and writes the file to the source cache 318. The crawler 31 6 then reads the file to 
determine if any additional assets (audio or image files) need to be fetched. If so, the crawler 31 6 fetches these assets. 
[0090] During this process, the crawler 316 keeps the browser 340 informed as to how many assets have been 

25 fetched and how many are left to fetch. When all the assets are fetched, the browser 340 makes a request to the ren- 
derer 320 to render the content The renderer 320 reads the HTML or TVML source data from the source cache 318, 
renders the content into FMB and markup language files, and writes these files to the rendered cache 330. 
[0091] When this is complete, the renderer 320 infomns the browser 340. The markup language file is read by the 
browser 340. thus informing the browser of the location of the FMB files and/or TVML i-frame files and audio files nec- 

30 essary to display the content The browser 340 then makes a request to the AVTS 345 to play a part of the FMB file 
(either a full screen as an i-frame, or part of a screen for a scroll or animated GIF update). The example then proceeds 
as stated above in example 3. 

Example 5: Image Amalgamation 

35 

[0092] The FMB format can also provide image amalgamation between two frames of data. The image amalgama- 
tion can include fading and wiping effects. In the example discussed below an i-frame and a p-frame can be sent to the 
client platform 360. Note that the use of the image amalgamation method discussed below can also implemented for 
two p-frames sent to the client platform 360. Also, the image amalgamation can be perfonned at the server complex 
40 prior to transmission of the frames to the client platform 360. 

[0093] As discussed above in the definitions section, a b-frame is a bi-directional predicted frame. For each b- 
frame, an i-frame and a p-frame can be used as references. 

[0094] In one example, three frames: I, B, P can be used to create a "fade" effect from the i-frame to the p-frame. 
The fade effect provides a smooth transition from the i-frame image to the p-frame image, e.g., a morphing effect. 
45 [0095] There are three pixels in the three frames with same position (x,y), e.g., I(x,y), B(x,y) and P{x,y). A difference 
between the i-frame and the b-frame. d(l,B), and a difference between between the b-frame and the p-frame, d{B,P), 
can be calculated as follows. 

d(I.B) = l(x,y)-B{x,y) 

50 

d(B,P) = P(x,y)-B(x.y) 

[0096] The average of these two differences can be obtained by: 

55 average = (d(l,B)+d(B,P))/2 

[0097] This "average" represents the average predicted error for frame B from frame I and from frame R Now, if we 
set the average = 0, then 
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d(l,B) + d(B,P) = 0, which means 

l(x.y) - B(x.y) + P(x.y) - B(x,y) = 0. so 

5 B(x.y) = (l(x,y) + P(x,y))/2 

[0098] If frame I and frame P have already been transmitted to the client platform 360, then transmitting one or 
more "zero B-frames" can enable the client platfomi 360 to generate the actual B frames. This can be accomplished by 
using the decode time-stamp (DTS) value placed in the data stream header by the AVTS 345. For example, if the i- 
10 frame has a DTS value of 0, and the p-frame has a DTS value of 4, then if the "zero-b-frame" has a DTS value of 2. the 
client platform 360 generates a image having values midway between the i-frame and p-frame values upon receipt of 
the empty b-frame. 

[0099] If the background is black, say "0", and the text is white, say "255", then on the screen, all the text will be 
shown in gray scale "128". The contrast of the text will be reduced. 

15 [0100] Alternatively, the ATVS 345 can send a series of three empty b-frames with DTS values of 1, 2, and 3, 
respectively to the client platform 360. In this case the first empty b-frame (with a DTS value of 1 ) causes the client plat- 
form 360 to display an image that represents the i-frame with 25% of the difference between the i-frame and the p- 
frame. e.g., 64, The second empty b-frame (with a DTS value of 2) causes the client platform 360 to display an image 
that represents the i-frame with 50% of the difference between the i-frame and the p-frame. The third empty b-frame 

20 (with a DTS value of 3) causes the client platform 360 to display an Image that represents the i-frame with 75% of the 
difference between the i-frame and the p-frame, e.g., 192. 

[0101] Based on this approach, a fade from the i-frame image to the p-frame image using one or more empty b- 
frames can be readily implemented using the FMB formatted data sets. The last b-frame transmitted to the client plat- 
form 360 can be exactly the same as the p-frame, which means that, B(x.y) = P(x,y) . In this circumstance, the following 
25 equations hold for the average predicted en-or. 

average = (d(I.B)+d(B.P))/2 
= (l(x,y)-B(x,y)-HP(x,y)-B(x,y))/2 

= (l(x,y)+P(x.y)-2B(x,y))/2, and therefore because B(x,y) = P{x,y) 
^ = (l(x,y)-P(x,y))/2 

[0102] Once we code these averages as a b-frame. the actual image for the last b-frame will be exactly the same 
as next p-frame. By changing these average errors gradually, the fade effect can be created. 
[0103] The ability to average the content of frames can also be used to generate a smooth 'wipe' of the screen from 
35 one image to another. A coarse wipe can be accomplished using only p-f names to replace the old image with a new one 
from left to right, top to bottom, or any combination thereof. But, using b-frames to average the data on the edge that is 
being moved to create the wipe effect results in a much smoother wipe effect. 

Example 6: Use of Markup Language Specifiers 

40 

[0104] Some embodiments of the invention use a mark-up language adapted to enable fat macroblock compres- 
sion techniques. For these embodiments, the frame element of the markup language describes a single independently 
scrollable "window" of a screen . A frame is composed of a static scrollable image that is typically stored as a fat mac- 
roblock, a set of active elements (e.g. forms, and animated GIFs), and a set of links (defined in the markup language 
45 as an anchorset). 

[0105] The frame can also include a set of assets to check against cookies (defined in the markup language as a 
cl element), and a set of hash reference locations (defined in the markup language as an hi element). The fat macrob- 
lock can be named using a (source) snc attribute. Other embodiments use different techniques, such as databases, to 
replace the function of the markup language description. The content stored can represent any image that includes par- 
se tial screen motion or partial screen updating, and is not limited to web pages. 

[0106] According to one mark-up language used with the FMB's, the size attribute is the absolute width and height 
of the entire frame contents in pixels. The coords attribute provides to position of the top left corner, and the width and 
height of the visible frame, or viewable portion of the image. According to this mark-up language, the size attribute and 
the coords attribute are mandatory attributes. 
55 [0107] The coordinates for the links of a frame are in the coordinate space of the frame. The browser 340 can adjust 
these coordinates depending on the location of the frame and the cun-ent scroll position. Note that the scrolling rate is 
application dependent. The renderer 320 can draw frame borders (and adjust frame positions and sizes accordingly). 
The browser 340 can also operate with frames that have been rendered in their entirety into one large frame. 
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[01081 A graphics language compression routine connpresses one strip of macroblocks at a time in the rectangular 
area passed to it. Upon completion of all strips, the compress routine returns back to the renderer 320 an array of inte- 
ger offsets, one for each processed strip. The compress routine also returns offsets to each macroblock in the strip back 
to the renderer 320. 

[0109] In some embodiments, the integer offsets and offsets returned to each macroblock can be stored in the FMB 
image header 21 0. Some embodiments use a markup language as a specifier The markup language file can store the 
list of integers as a comma delimited string of numbers in the "offsets" attribute of any "src' file that is an FMB file (e.g., 
as static, form elements and animated GIFs). Additionally, the compress routines can put the integer values into the 
fixed size header in the FMB file itself. If the HTML page is too long, the header in the FMB file will overflow, the page 
will not be viewable to the user, and the operation should be aborted. 

[0110] In some embodiments, each strip begins on an 8-byte boundary Each strip includes the aforementioned 
header, then padding to the next 8-byte boundary, and then the macroblocks for the strip, all bit-wise packed together. 
[0111] Each strip header entry in the FMB image header 210 contains the bit starting location for each macroblock 
in the strip, as well as the absolute DC component for each macroblock. The bit starting locations and absolute DC com- 
ponent enable the AVTS 345 to readily adjust the first macroblock pulled out of a strip (e.g., when displaying something, 
there may be horizontal scrolling, in which the first macroblock to display may not be the first macroblock in the strip). 
[0112] MPEG encoded frames sent to a set top box contain a series of horizontal slices that are represented by cor- 
responding strips of fat macroblocks. In a television screen of 480 vertical pixels, and with each MPEG macroblock 
being defined as 16x16 pixels, there will be 30 strips of fat macroblocks. A screen width of 640 pixels will be 40 mac- 
roblocks wide. A screen width of 704 pixels will be 44 macroblocks wide. 

[0113] In order to reliably update video data for a display 370, data representing each horizontal slice in a frame 
needs to be present. However, only the first macroblock of a strip needs to actually be in the frame. This frame config- 
uration is allowed because a macroblock can be implied to be present either by the skip value in the macroblock (right 
after a missing section), or by there being no more macroblocks before the start of a new strip of macroblocks. 
[0114] If the first macroblock of a strip is not changing, it is customary to send down a motion vector for the first 
macroblock. The motion vector specifies that the macroblock is to be sourced from that very same location, as opposed 
to downloading the macroblock itself (which is comparatively bigger). This is called a zero displacement motion vector. 
In some embodiments, additional values can be supplied in a motion vector. 

[0115] Typically, a strip representing a image slice will either specify a new (replacement) macroblock for the first 
macroblock in the strip, or specify a zero displacement motion vector. Following the first macroblock representation, the 
strip will contain zero, one or more macroblock. In some circumstances, holes are placed between the subsequent mac- 
roblocks. The holes can be represented by a skip counter in the next macroblock. 

[0116] In frames fonnatted according to some embodiments of the invention, each strip can contain macroblocks 
or groups of macroblocks from several different FMB files. 

[0117] The lAE can output a series of commands to the AVTS 345 as to which blocks to include in the frame to be 
sent to the set top box. The lAE can also send "updates" to the AVTS 345 in order to provide scrolling, animated GIFs, 
and changed areas on the display 370 due to form elements. 

[0118] In some embodiments, the AVTS 345 does not maintain any context, and thus needs to be informed explic- 
itly as to what macroblocks are to be sent, and from which FMB files these macroblocks can be sourced. 
[0119] According to one approach, the lAE builds an in-memory representation of the screen in a 44x30 array of 
"macroblocks". The lAE does not have actual access to any macroblocks. However, the lAE does have knowledge 
about which macroblocks are needed and where the macroblocks come from. 

[0120] In some circumstances, other factors need to be considered. The screen can be built up from a number of 
FMB files, some representation HTML frames, static areas such as frame borders, the static portion within each HTML 
frame, and a number of variable elements within an HTML frame. The variable elements in the HTML frame can include 
form elements, animated GIFs, motion in a window, and runtime selectable window substitutions (for example, user 
specific advertisements). 

[0121] Once an initial frame is sent (i-frames contain actual macroblocks for everywhere on the screen), the lAE 
can send partial frames (P-frames contain macroblocks for only those areas that change on the display 370). 
[0122] All the disclosed embodiments of the invention described herein can be realized and practiced without 
undue experimentation. Although the best mode of can7ing out the invention contemplated by the inventors is disclosed 
above, practice of the invention is not limited thereto. Accordingly, it will be appreciated by those skilled in the art that 
the invention may be practiced othenvise than as specifically described herein. 

[0123] For example, all the disclosed elements and features of each disclosed embodiment can be combined with, 
or substituted for, the disclosed elements and features of every other disclosed embodiment except where such ele- 
ments or features are mutually exclusive. 

[0124] It will be manifest that various additions, modifications and rearrangements of the features of the invention 
may be made without deviating from the spirit and scope of the underlying inventive concept. It is intended that the 
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scope of the invention as defined by the appended claims and their equivalents cover all such additions, modifications, 
and rearrangements. The appended claims are not to be interpreted as including means-plus-function limitations, 
unless such a limitation is explicitly recited in a given claim using the phrase "means-for." Expedient embodiments of 
the invention are differentiated by the appended sub-claims. 

Claims 

1. A method of preparing multimedia data for transmission using digital video data compression in a computer, the 
method comprising: 

pre-rendering a bitmap to create a compressed form of the bitmap, the bitmap including content of a series of 
video images of the multimedia data, the video images having a full-sized area; and 

detemninlng a viewable area of the video images to be displayed the viewable area of the video images is 
smaller than the full-sized area. 

2. The method of preparing multimedia data of claim 1 , wherein: 

the content includes at least one of fixed content and variable content, the fixed content having a lifetime in the 
series of video images, and portions of the variable content having lifetimes less than the lifetime of the fixed 
content; and 

the method further comprises encoding the content as at least one data set formatted as at least one fat mac- 
roblock, each fat macroblock represents a rectangular area of pixels in the series of video images, each fat 
macroblock includes information enabling processing for transmitting frames of data representing portions of 
the video images. 

3. The method of preparing multimedia data of claim 2, including: 

designating screen areas for updating; 

designating macroblocks corresponding to the screen areas; 

responsive to a designation for updating an entire screen, generating an intra frame from corresponding mac- 
roblock data; and 

responsive to a designation for updating a subset of the screen, creating one of a predicted frame and a bi- 
directional frame including macroblocks required for the updating of the subset of the screen. 

4. The method of preparing multimedia data of claim 3, wherein: 

the content includes multimedia elements; and 

the method further comprises, responsive to user input, changing the content, the changing including collect- 
ing macroblocks to be changed for each element to be changed. 

5. The method of preparing multimedia data of claim 4, further comprising rendering the content of the video image, 
the rendering including: 

extracting selected sections of bitmaps for variable multimedia elements; 

saving the selected sections; and 

rendering the selected sections into updated macroblocks. 

6. The method of preparing multimedia data of claim 5, wherein: 

the encoding is pertonmed according to MPEG specifications; and 

the method further comprises marking the bitmap with the updated macroblocks. 
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The method of preparing multimedia data of claim 6, further comprising creating one of a predicted frame and a bi- 
directional frame including the updated macrobloclcs, the creating including determining any required motion vec- 
tors for the updated macroblocks. 

The method of preparing multimedia data of claim 5, wherein the video images include animation, the animation 
corresponds to fat macroblocks containing each frame of an animated sequence of images. 

The method of preparing multimedia data of claim 5, further comprising 

updating macroblocl<s for a portion of the viewable area corresponding to a picture-in -picture display, the 
updated macroblocl<s including one or more of predicted frames and bi-directional frames including images 
corresponding to full motion for the picture-in-picture display. 

The method of preparing multimedia data of claim 9, wherein the updating includes one or more of: 

using motion vectors for panning; 

completely replacing the macroblocks corresponding to the picture-in-picture display; and 
20 using data streams transmitted in real-time from at least one live video source. 

11. The method of preparing multimedia data of claim 5, wherein the video images include smooth scrolling the view- 
able area, the viewable area provided as a screen image on at least one of the displays, the smooth scrolling includ- 
ing: 

25 

moving the viewable region a distance corresponding to at least one macroblock, the moving creating a miss- 
ing region on the screen Image; 

filling the missing region with macroblock data using motion vectors; and 
replacing the screen image. 

30 

12. The method of preparing multimedia data of claim 5, further comprising amalgamating an image between a first 
frame of data and a second frame of data, the amalgamating including generating at least one bi-directional frame 
corresponding to values disposed between first frame values and second frame pixel values. 

35 13. The method of preparing multimedia data of claim 12, wherein the encoding provides values within the macrob- 
locks in compressed forms with different quantization factors. 

14. The method of preparing multimedia data of claim 12, wherein: 

40 the first frame comprises an intra-frame having a first decoder time stamp value; 

the second frame comprises a predicted frame having a second decoder time stamp value; and 

the at least one bi-directional frame includes at least one zero frame having a decoder time stamp value 
45 greater than the first time stamp value and less than the second time. 

15. The method of preparing multimedia data of claim 12. wherein the amalgamating includes one of fading and wiping. 

16. The method of preparing multimedia data of claim 3. wherein: 

50 

the content includes multimedia elements; and 

the method further comprises, responsive to at least one of predetermined timing, calculated timing, and ran- 
dom timing, changing the content, the changing including collecting macroblocks to be changed for each mul- 
55 timedia element to be changed. 

17. The method of preparing multimedia data of claim 2, wherein: 
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the content includes variable multimedia elements; and 

the method further comprises, when transmitting, determining the variable content to update a group of the var- 
iable multimedia elements from selected sections disposed in at least one strip of fat macroblocks, each strip 
represents a horizontal area of one video image in the series of video images. 

18. The method of preparing multimedia data of claim 17, wherein: 

each macrobiock represents a square anray of pixels including N pixels on each side of the square array, N is 
an even number; 

the variable multimedia elements include passive areas and active areas, the active areas include content sub- 
ject to change during the lifetime of the variable content; and 

pre-rendering includes formatting the active areas to ensure that no active area of a first variable element 
shares a macrobiock with any active area of another variable multimedia element. 

19. The method of preparing multimedia data of claim 18, wherein the pre-rendering includes placing a border enclos- 
ing each active area, the border enclosing each active area extends outward from the corresponding active area by 
at least approximately N/2 pixels. 

20. The method of preparing multimedia data of claim 1 8, wherein encoding includes saving a group of the active areas 
as bitmap files. 

21. The method of preparing multimedia data of claim 20. wherein the bitmap files and fat macroblocks are tracked 
using a specifier, the specifier including one of a look-up table, and a markup language. 

22. The method of preparing multimedia data of claim 1 8, wherein the frames of data correspond to the active areas. 

23. The method of preparing multimedia data of claim 17, including: 

rendering new values for the selected sections; and 
re-encoding the new values into macroblocks. 

24. The method of preparing multimedia data of claim 2, wherein each fat macrobiock includes macrobiock data and a 
header, the header including encoding parameters for the macrobiock. 

25. The method of preparing multimedia data of claim 24, further comprising indexing a group of fat macroblocks as a 
data set including fat macrobiock information organized into strips, each strip includes an indication of a location 
within the strip for each macrobiock disposed in the strip. 

26. The method of preparing multimedia data of claim 25, wherein 

encoding includes compressing data disposed in the macroblocks. 

27. The method of preparing multimedia data of claim 26, wherein: 

each strip has the same number of macroblocks; and 

the macroblocks vary in size due to the compression of data disposed in the macroblocks. 

28. The method of preparing multimedia data of claim 26, wherein: 

compressing is performed according to a compression routine; 
compressing occurs for one strip of macroblocks at a time; and 

upon completion of compressing of all of the strips, the compression routine provides an array of integer offsets 
to a renderer, each of the integer offsets corresponds to a compressed strip. 

29. The method of preparing multimedia data of claim 24, wherein the encoding parameters include a quantization fac- 
tor. 
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30. The method of preparing multimedia data of claim 2, wherein the frames include portions from more different fat 
macroblock data sets. 

31. The method of preparing multimedia data of claim 2, wherein the encoding is performed according to MPEG tech- 
5 niques. 

32. The method of preparing multimedia data of claim 2, wherein encoding includes compressing data disposed in the 
macroblocks. 

w 33. The method of preparing multimedia data of claim 1 , wherein: 

the pre-rendering includes separating the content into regions of the video images, the separating performed 
according to a directive; 

75 data processing steps performed after pre-rendering are applied by region; and 

information obtained from the data processing steps performed after pre-rendering is maintained separately by 
region. 

20 34. The method of preparing multimedia data of claim 33, further comprising: 

determining regions having higher resolution requirements according to the directive; and 

applying a different quantization factor to macroblocks corresponding to the regions having higher resolution 
25 requirements. 

35, The method of preparing multimedia data of claim 1, further comprising rendering, the rendering including: 

extracting selected sections of bitmaps for variable elements of the video image; and 
30 saving the selected sections, the variable elements including content subject to change during a viewing 

period. 

36. The method of preparing multimedia data of claim 35, wherein: 

35 the content includes fixed content having static elements, the static elements include at least one of a back- 

ground color, and a bitmap corresponding to a portion of the video images; and 

the variable elements include at least one of a form element, and an animated graphics file. 

40 37. The method of preparing multimedia data of claim 1 , wherein the display has a viewing size, and the viewing size 
is different than the full size area. 

38. The method of preparing multimedia data of claim 1 , wherein: 

45 each of the video images is represented by macroblocks of data, each of the macroblocks is relaxed to a plu- 

rality of pixels con-esponding to a geometrical portion of the video image; 

the video image includes variable content having active areas in which content is subject to change as the var- 
iable content changes, and passive areas in which content does not change as the variable content changes; 
50 and 

pre-rendering includes formatting the active areas to ensure that no active area of a first variable element 
shares a macroblock with any active area of another variable element. 

55 39. A method for transmitting multimedia data using digital video data compression, comprising: 

pre-rendering a bitmap to create a compressed form of the bitmap, the bitmap including content of a series of 
video images of the multimedia data, the video images having a full-sized area; 
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determining a viewable area of the video images to be displayed, the viewable area is smaller than the full- 
sized area; and 

transmitting frames of data representing portions of the video images to processing equipment, the processing 
equipment is connected to at least one display. 

40. The method for transmitting multimedia data of claim 39, wherein: 

the content includes at least one of fixed content and variable content, the fixed content having a lifetime in the 
series of video images, and portions of the variable content having lifetimes less than the lifetime of the fixed 
content; and 

the method including, prior to transmitting, encoding the content as at least one data set formatted as at least 
one fat macroblock, each fat macroblock represents a rectangular area of pixels in the series of video images, 
each fat macroblock includes Information enabling processing for transmitting the frames and displaying the 
series of video images. 

41. The method for transmitting multimedia data of claim 40, wherein: 

the content includes multimedia elements; and 

the method further comprises, when transmitting, determining the variable content to update a first group of 
variable elements from selected sections disposed in at least one strip of fat macroblocks, each strip repre- 
sents a horizontal area of one video image in the series of video images. 

42. The method for transmitting multimedia data of claim 41 , wherein: 

each macroblock conresponds to a square array of pixels including N pixels on each side of the square array, 
N is an even number; 

the variable elements include passive areas and active areas, the active areas including content subject to 
change during the lifetime of the variable content; and 

pre- rendering includes formatting the active areas to ensure that no active area of a first variable element 
shares a macroblock with any active area of another variable element. 

43. The method for transmitting multimedia data of claim 40, including: 

designating screen areas for updating; 

designating macroblocks corresponding to the screen areas; 

responsive to a designation for updating an entire screen, generating an intra frame from corresponding mac- 
roblock data; and 

responsive to a designation for updating a subset of the screen, creating one of a predicted frame and a bi- 
directional frame including macroblocks required for the updating of the subset of the screen. 

44. The method for transmitting multimedia data of claim 43, wherein: 

the encoding is perfomied according to MPEG specifications; and 

the method further comprises marking the bitmap with the updated macroblocks. 

45. The method for transmitting multimedia data of claim 44, further comprising creating one of a predicted frame and 
a bi-directional frame including the updated macroblocks, the creating including determining any required motion 
vectors for the updated macroblocks. 

46. The method for transmitting multimedia data of claim 44, wherein the video images include animation, the anima- 
tion corresponds to fat macroblocks containing each frame of an animated sequence of images. 

47. The method for transmitting multimedia data of claim 40, wherein the frames include portions from more than one 
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fat macroblock data set. 

48. A method of distributing Internet data to digital cable devices connp rising: 

5 pulling initial content from the Internet; 

pre-rendering a bitmap corresponding to the initial content to create a compressed fonm of the bitmap, the bit- 
map corresponding to a series of video images of the multimedia data, the video images having a full-sized 
area; 

w 

determining a viewable area of the video images to be displayed, the viewable area of the video images is 
smaller than the full-size area; and 

transmitting frames of data representing portions of the video images to digital cable processing equipment, 
15 the digital cable processing equipment is connected to displays for more than one user. 

49. The method of distributing Internet data of claim 48, wherein: 

the initial content includes at least one of fixed content and variable content, the fixed content having a lifetime 
20 in the series of video images, and portions of the variable content having lifetimes less than the lifetime of the 

fixed content; and 

the method further comprises encoding the initial content as at least one data set formatted as at least one fat 
macroblock, each fat macroblock represents a rectangular area of pixels in the series of video images, and 
each fat macroblock includes information enabling processing for transmitting the frames of data representing 
25 portions of the video images. 

50. A method of using a television channel to provide Internet access comprising: 

pulling initial content from the Internet; 

30 

pre-rendering a bitmap corresponding to the initial content to create a compressed form of the bitmap, the bit- 
map corresponding to a series of video images of the multimedia data, the video images having a full-sized 
area; 

35 determining a viewable area of the video images to be displayed, the viewable area of the video images is 

smaller than the full-size area; 

storing multimedia data elements including the bitmap in a server system; 
40 multiplexing the multimedia data elements into frames of data; 

transmitting frames of data from the server system to a cable network; 

transmitting streams of data representing portions of the video images in a television channel to digital cable 
45 processing equipment, the digital cable processing equipment is connected to at least one display for a user. 

51. The method of using a television channel of claim 50, wherein: 

the initial content includes at least one of fixed content and variable content, the fixed content having a lifetime 
50 in the series of video images, and portions of the variable content having lifetimes less than the lifetime of the 

fixed content; and 

the method further comprises encoding the initial content as at least one data set formatted as at least one fat 
macroblock, each fat macroblock represents a rectangular area of pixels in the series of video images, and 
55 each fat macroblock includes information enabling processing for transmitting the frames of data representing 

portions of the video images. 

52. A method of providing a picture-in-picture display comprising: 
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pre-rendering a bitmap to create a compressed form of the bitmap, the bitmap including content of a series of 
video images of the multimedia data, the video images having a full-sized area; 

determining a viewable area of the video images to be displayed, the viewable area of the video images is 
smaller than the full-sized area; 

rendering the content of the video image; and 

updating macroblocks for a portion of the viewable area corresponding to a picture-in-picture display, the 
updated macroblocks including one or more of predicted frames and bi-directional frames including images 
corresponding to full motion for the picture-in-picture display. 

53. The method of providing a picture-in-picture display of claim 52, wherein the rendering includes: 

extracting selected sections of bitmaps for the variable elements; 

saving the selected sections; and 

rendering the selected sections into updated macroblocks. 

54. A system for transmitting multimedia data using digital video compression, the system comprising: 

a crawler adapted to: 

update references to media assets disposed in markup language files; and 
provide content including markup language files to a renderer; 

the renderer is adapted to render the content into fat macroblock formatted data sets; 
a rendered cache adapted to store files of the fat macroblock fonnatted data sets; 
a server adapted to; 

submit requests for data to a browser; and 

deliver encoded multimedia data streams to a cable network; 

the browser is adapted to: 

respond to requests from the server by collecting data from the crawler and the rendered cache; and 

submit the collected data to the server. 

55. The system for transmitting multimedia data of claim 54, wherein: 

the cable network is adapted to: 

receive data streams from the server; and 

transmit streams of compressed data including the fat macroblock data in at least one communication 
channel to client platforms; and 

the system further comprises client platfonns having decoders adapted to receive the compressed data 
streams from the cable network. 

56. The system for transmitting multimedia data of claim 55, wherein: 

the content includes fixed content and variable content, the variable content having variable multimedia ele- 
ments, portions of the variable content having lifetimes less than a lifetime of fixed content; 
the crawler is adapted to provide content to the browser; and 
the system further comprises: 

a source cache adapted to store the content, including the updated references to the media assets pro- 
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vided by the crawler; and 

a compression routine coupled to the renderer to: 

encode content for a series of video images as at least one data set formatted as at least one fat mac- 
roblock, each fat macroblock represents a rectangular area of pixels in the series of video images, 
each fat macroblock includes infomiation enabling processing for transmitting frames of data repre- 
senting portions of the video images; 

extract selected sections of bitmaps for the variable multimedia elements; 

save the selected sections; and 

render the selected sections into updated macroblocks. 

57. The system for transmitting multimedia data of claim 54, wherein each fat macroblock includes macroblock data 
and a header, the header including encoding parameters for the macroblock. 

58. A system for preparing multimedia data for transmission using digital video compression in a computer, the system 
comprising: 

means for pre-rendering a bitmap to create a compressed form of the bitmap, the bitmap including content of 
a series of video images of the multimedia data, the video images having a full-sized area; and 

means for determining a viewable area of the video images to be displayed, the viewable area of the video 
images is smaller than the full-sized area. 

59. A system for transmitting multimedia data using digital video compression, the system comprising: 

means for updating references to media assets disposed in markup language files; 
means for providing content including markup language files to rendering means; 
the rendering means for rendering the content into fat macroblock formatted data sets; 
storage means for storing files of the fat macroblock fomnatted data sets; 

computing means for submitting requests for data to browsing means; and for delivering encoded multimedia 
data streams to networking means; 

the browsing means for responding to requests from the computing by collecting data from the means for 
updating references and the storage means; and submitting the collected data to the computing means. 
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